Øyvind Kolås [Wed, 11 Jul 2018 23:24:42 +0000 (01:24 +0200)]
extensions/u32: add ~ model/format support
Øyvind Kolås [Wed, 11 Jul 2018 23:24:26 +0000 (01:24 +0200)]
extensions/u16; add ~ model/format support
Øyvind Kolås [Wed, 11 Jul 2018 23:22:35 +0000 (01:22 +0200)]
extensions/float: add ~ variants of conversions
Michael Natterer [Wed, 11 Jul 2018 21:57:40 +0000 (23:57 +0200)]
Change the license URL from gnu.org/licenses/ to https://
Øyvind Kolås [Wed, 11 Jul 2018 21:35:59 +0000 (23:35 +0200)]
babl: add babl_model_is, utility function for checking model equivalence
This creates an on the fly model with the same space as the one compared with
and does pointer equivalence. Using it makes for less verbose code.
Øyvind Kolås [Wed, 11 Jul 2018 21:23:08 +0000 (23:23 +0200)]
babl: make babl_model_with_space able to take format/model for space
Øyvind Kolås [Wed, 11 Jul 2018 20:57:59 +0000 (22:57 +0200)]
babl.h: add documentation
Øyvind Kolås [Wed, 11 Jul 2018 20:47:30 +0000 (22:47 +0200)]
babl: make equalize_matrix argument an enum
Øyvind Kolås [Wed, 11 Jul 2018 19:48:10 +0000 (21:48 +0200)]
babl: make babl_space_to_icc symbol internal
Øyvind Kolås [Wed, 11 Jul 2018 19:11:17 +0000 (21:11 +0200)]
babl-space: add comments, do not use a static temp struct
Øyvind Kolås [Wed, 11 Jul 2018 18:35:40 +0000 (20:35 +0200)]
babl: add babl_space_get_icc
Øyvind Kolås [Wed, 11 Jul 2018 18:35:37 +0000 (20:35 +0200)]
babl: simplify the singleton logic in babl_format_with_space
Øyvind Kolås [Wed, 11 Jul 2018 15:07:52 +0000 (17:07 +0200)]
babl: export symbol model_with_space
Øyvind Kolås [Mon, 9 Jul 2018 20:58:55 +0000 (22:58 +0200)]
babl: add babl_space_get
An accessor for getting back out the chromaticities of whitepoint and primaries
as well as trcs.
Øyvind Kolås [Mon, 9 Jul 2018 14:48:05 +0000 (16:48 +0200)]
babl: add separate LUTs for rTRC,gTRC and bTRC in generic fast paths
Øyvind Kolås [Mon, 9 Jul 2018 14:29:42 +0000 (16:29 +0200)]
babl: fix bug in icc tag alignment
Øyvind Kolås [Sun, 8 Jul 2018 20:38:25 +0000 (22:38 +0200)]
babl: export symbol babl_space_to_icc
Øyvind Kolås [Sun, 8 Jul 2018 13:54:58 +0000 (15:54 +0200)]
babl: export more symbols
Adding babl_chromaticities_make_space, babl_trc and
babl_trc_gamma to public api and ability to setup arbitrary
BablSpaces without loading from ICC profiles.
Øyvind Kolås [Sat, 7 Jul 2018 20:46:50 +0000 (22:46 +0200)]
extensions/two-table: temporarily disable
When viewing PNGs with attached ICC profiles the gegl binary produces black
if the two-table extension is active. Something is wrong in babl even accepting
these paths.
Andrea Veri [Tue, 3 Jul 2018 09:58:13 +0000 (09:58 +0000)]
Drop newlines between tags
Øyvind Kolås [Mon, 2 Jul 2018 14:03:43 +0000 (16:03 +0200)]
post-release version bump
Øyvind Kolås [Mon, 2 Jul 2018 13:42:15 +0000 (15:42 +0200)]
release 0.1.52
Øyvind Kolås [Mon, 2 Jul 2018 13:41:59 +0000 (15:41 +0200)]
export-symbols: export babl_trc
Øyvind Kolås [Mon, 2 Jul 2018 13:41:01 +0000 (15:41 +0200)]
NEWS: update
Ell [Mon, 25 Jun 2018 13:29:08 +0000 (09:29 -0400)]
babl-palette: fix default palette double-data size
Øyvind Kolås [Sun, 24 Jun 2018 09:56:18 +0000 (11:56 +0200)]
babl: fix trc registrationof ACES spaces
Øyvind Kolås [Sat, 23 Jun 2018 20:32:20 +0000 (22:32 +0200)]
babl: predefine ACEScg and ACES2065-1 BablSpaces
Øyvind Kolås [Thu, 21 Jun 2018 12:49:12 +0000 (14:49 +0200)]
tests: add format_with_space test
Testing that both R'G'B' formats and CIE Lab float keep the space they have
been created with.
Øyvind Kolås [Wed, 20 Jun 2018 19:04:46 +0000 (21:04 +0200)]
babl: refactor format registration to loop over types
Also register full set of R~G~B~ and Y~ formats for all the types.
Øyvind Kolås [Wed, 20 Jun 2018 18:43:53 +0000 (20:43 +0200)]
babl: add ~ variants to gray color models
We do not add premultiplied sRGB trc variants even if this exists for RGB
since it is the type of premultiplied alpha cairo expects. The less code
that does non-linear compositing the better, excluding some possibilities
also reduces the combinatorial overhead of finding conversion paths in babl.
Øyvind Kolås [Wed, 20 Jun 2018 10:33:28 +0000 (12:33 +0200)]
babl: add R~G~B~ color models and pixel formats
From a given BablSpace which defines RGB chromaticities and
per component TRCs, the following are the defined formats:
R'G'B' with the TRCs applied
RGB linear data
and now a new one
R~G~B~ with the sRGB TRC, this permits any BablSpace to be the
native format of a buffer in an application while having both
a 'perceptual' in R~G~B~ and linear in RGB that is possible
to derive from it. Importantly it is also possible to recover
the babl space used to create the buffer.
Øyvind Kolås [Wed, 20 Jun 2018 17:35:43 +0000 (19:35 +0200)]
babl: clarify internal gray babl-id enums
Use GRAY_LINEAR and GRAY_NONLINEAR making the introduction of PERCEPTUAL
easier.
Øyvind Kolås [Wed, 20 Jun 2018 10:55:55 +0000 (12:55 +0200)]
babl: remove outdated comment
Øyvind Kolås [Tue, 19 Jun 2018 17:29:48 +0000 (19:29 +0200)]
babl: rename functions that used to refer to specific gamma
The definitions of components and formats for linear and nonlinear formats in
model-rgb and model-gray are now using the TRC of a BablSpace, thus in the
format syntax ' now means nonlinear, not sRGB / 2.2 gamma - even though it ends
up meaning that for formats create without specifying the space.
Ell [Thu, 14 Jun 2018 06:16:08 +0000 (02:16 -0400)]
babl-palette: warn when trying to create a palette with > 256 colors
... and only use the first 256 colors.
Ell [Thu, 14 Jun 2018 05:54:52 +0000 (01:54 -0400)]
babl-fish: fix concurrent babl_fish()/process() calls with palette formats
In babl_fish(), don't call _babl_fish_rig_dispatch() on existing
path fishes during each lookup. We already call this function on
all path fishes upon creation (in particular, after commit
b34a9672c8c9a42923a8f0b2650af30b1efe635c), so this isn't necessary.
This fixes an issue where the _babl_fish_rig_dispatch() call in
babl_fish() would temporarily modify the value of babl->fish.data,
causing a concurrent babl_process[_rows]() call in another thread
to pass the wrong 'data' value down to the conversion function. In
particular, this could cause palette conversions to segfault.
Elle Stone [Sat, 9 Jun 2018 17:18:43 +0000 (19:18 +0200)]
babl: fix fixed to double conversions
See issue #18 https://gitlab.gnome.org/GNOME/babl/issues/18
Øyvind Kolås [Sat, 9 Jun 2018 17:11:26 +0000 (19:11 +0200)]
babl-space: babl_space_new_from_chromaticities add equalize_matrix argument
Part of the problem in issue #18
This API is internal only for now so we can change it, changing to use a
hard-coded pre-quantized chromaticities set for the internal sRGB space.
This preserve the gray axis matrix equalization performed for other spaces used
with babl, ideally we can improve the gray-axis equalization to match and
return to using it also for sRGB.
Ell [Wed, 30 May 2018 10:01:27 +0000 (06:01 -0400)]
babl-palette: warn when trying to create a 0-color palette
In babl_palette_set_palette(), fall back to the default palette,
and log a warning, when trying to create a palette with < 1 colors.
Ell [Wed, 30 May 2018 09:45:17 +0000 (05:45 -0400)]
babl-memory: allow babl_malloc(0) to succeed
Allow a babl_malloc() call with size == 0 to succeed, returning a
dummy allocation, instead of asserting on this condition. The new
babl-palette code tries to allocate an empty buffer for the radii
array when creating a single-color palette, which would previously
lead to a crash.
Ell [Fri, 25 May 2018 12:52:47 +0000 (08:52 -0400)]
babl-palette: fix default-palette radii array size
Ell [Thu, 24 May 2018 14:55:17 +0000 (10:55 -0400)]
babl-palette: make default palette initialization thread-safe
... and allocate its radii statically.
Øyvind Kolås [Sun, 20 May 2018 08:49:52 +0000 (10:49 +0200)]
post release version bump
Øyvind Kolås [Sun, 20 May 2018 08:45:46 +0000 (10:45 +0200)]
release 0.1.50
Edward E [Sun, 1 Apr 2018 06:23:45 +0000 (01:23 -0500)]
Fix an unimportant typo
What's in a name? S.E.P.
Ell [Sat, 19 May 2018 12:28:19 +0000 (08:28 -0400)]
tests: fix palette-concurrency-stress-test
Fix palette-concurrency-stress-test to accommodate the change to a
gamma-corrected 8-bit format (commit
fabcc6729ed453fb5c5affc565d0e837a78afc5c), and to little-endian
hash indices (commit
55ca45c8233af138d3fd388587b203d802b8396c).
The test should pass regardless, it simply didn't actually test for
the intended issue previously.
Øyvind Kolås [Sat, 19 May 2018 11:35:04 +0000 (13:35 +0200)]
tools: code around gcc warning about 0 length format string
John Marshall [Sat, 19 May 2018 11:08:12 +0000 (12:08 +0100)]
Meson build: fixes for windows build
John Marshall [Sat, 19 May 2018 10:53:51 +0000 (11:53 +0100)]
Meson build: generate png image files for docs
John Marshall [Sat, 19 May 2018 10:51:30 +0000 (11:51 +0100)]
Meson build: Improve git-version.h generation
John Marshall [Sat, 19 May 2018 10:48:26 +0000 (11:48 +0100)]
Meson build: Tidy up code and improve readability
John Marshall [Sat, 19 May 2018 10:38:18 +0000 (11:38 +0100)]
Meson build: improve doc generation
John Marshall [Sat, 19 May 2018 10:36:45 +0000 (11:36 +0100)]
Meson build: Improve host environment detection / handling
John Marshall [Sat, 19 May 2018 10:01:46 +0000 (11:01 +0100)]
Meson build: Improve SIMD assembly checking/use
Ell [Fri, 18 May 2018 13:01:26 +0000 (09:01 -0400)]
babl-palette: initialize radii of default palette
... to prevent a segfault when using the default palette, namely,
in tests/palette.
Ell [Fri, 18 May 2018 12:04:52 +0000 (08:04 -0400)]
babl-palette: speed up closest-color search
When constructing a palette format, calculate the distance between
each pair of colors in the palette, and for each color, construct a
list of all other colors and their distances from it, sorted by
distance. When searching for the closest palette color to a given
input pixel, based on the assumption that nearby pixels have
similar color, use the color list of the previous pixel's best
match, and use the triangle inequality to stop the search early.
See the code comments for more details.
Øyvind Kolås [Fri, 18 May 2018 09:02:04 +0000 (11:02 +0200)]
babl: use hashtable approach in double reference
Strictly speaking we should be doing the reference using
conversions to R'G'B'A double and using the distance metric
there; possibly getting a slight difference in result at
comparison ties.
In use GEGL ends up using both the really fast 8bit code paths
and the quite fast floating point code paths that use 8bit
hashtables for the lookup of conversion.
Progress on bug #787237 missing fast-paths.
Øyvind Kolås [Thu, 17 May 2018 14:24:49 +0000 (16:24 +0200)]
babl-palette: fix regression in prefvious commit
The 255.5 factor for storing a double represenation is neccesary for
desired behavior.
Øyvind Kolås [Thu, 17 May 2018 12:33:07 +0000 (14:33 +0200)]
babl-palette: improvements toward palette accuracy
For working at acceptable performance with large indexed images, it is
recommended to run with BABL_TOLERANCE=0.0385 or highger set in the environment
when launching GIMP, this permits using a hashtable based optimization that
still isn't accurate enough according to babl-expectations.
Part of progress on bug 787237
Øyvind Kolås [Thu, 17 May 2018 10:53:42 +0000 (12:53 +0200)]
meson.build: synchronise with autotools version
WARNING: distributions should still not use meson to build packages - since
the meson build end up containing all instructions available on build host.
Jan Vesely [Thu, 17 May 2018 04:04:04 +0000 (00:04 -0400)]
meson.build: Bump version to 0.1.48
Signed-off-by: Jan Vesely <jano.vesely@gmail.com>
Øyvind Kolås [Wed, 16 May 2018 11:13:26 +0000 (13:13 +0200)]
babl: preliminary work to add float fast path to palette formats
Still not accurate enough to be acceptable, gets accepted by system with
a BABL_TOLERANCe of 0.045 or higher. Needs more work.
Øyvind Kolås [Tue, 15 May 2018 19:29:56 +0000 (21:29 +0200)]
post release version bump
Øyvind Kolås [Tue, 15 May 2018 19:28:11 +0000 (21:28 +0200)]
release 0.1.48
Øyvind Kolås [Tue, 15 May 2018 19:06:16 +0000 (21:06 +0200)]
configure: try to add -Ofast to CFLAGS
Debarshi Ray [Mon, 14 May 2018 14:04:27 +0000 (16:04 +0200)]
Debarshi Ray [Mon, 14 May 2018 09:24:27 +0000 (11:24 +0200)]
CIE: Add an SSE2 version of "RGBA float" to "CIE L float"
On an Intel i7 Haswell, it now takes 0.056s to convert a 15 megapixel
buffer from "RGBA float" to "CIE L float" instead of the earlier
0.107s.
https://bugzilla.gnome.org/show_bug.cgi?id=795686
Debarshi Ray [Sat, 28 Apr 2018 23:15:46 +0000 (01:15 +0200)]
CIE: Add an SSE2 version of "RGBA float" to "CIE Lab alpha float"
On an Intel i7 Haswell, it now takes 0.13s to convert a 15 megapixel
buffer from "RGBA float" to "CIE Lab alpha float" instead of the
earlier 0.27s.
SSEx doesn't have integer multiplication or division operations, and
using bit shifts to implement integer divisions by powers of 2 seems to
introduce errors. Therefore, it was problematic to use the cube root
approximation from Hacker's Delight, which uses quite a few integer
divisions to make the initial guess. Instead, Halley's method of
approximating the cube root seems more SSEx friendly because the
initial guess requires only one integer division, which we can manage
by jumping through a relatively small number of hoops.
The scalar version of Halley's method seems to have originated from
http://metamerist.com/cbrt/cbrt.htm but that's not accessible anymore.
At present there's a copy in CubeRoot.cpp in the Skia sources that's
licensed under a BSD-style license. There's some discussion on the
implementation at http://www.voidcn.com/article/p-gpwztojr-wt.html.
Note that Darktable also has an SSE2 version of the same algorithm,
but uses only a single iteration of Halley's method, which is too
coarse.
Here's some more discussion on the cube root approximation algorithms:
https://bugzilla.gnome.org/show_bug.cgi?id=791837
https://bugzilla.gnome.org/show_bug.cgi?id=795686
Debarshi Ray [Sun, 29 Apr 2018 21:57:42 +0000 (23:57 +0200)]
build: Add scaffolding for SSE3
It's currently unused, but is useful to have it around when comparing
different vectorization strategies.
https://bugzilla.gnome.org/show_bug.cgi?id=795686
Debarshi Ray [Sat, 28 Apr 2018 22:21:44 +0000 (00:21 +0200)]
CIE: Make the XYZ to LAB code look similar to the RGB to LAB code
Such superficial differences make the code harder to scan when looking
for bugs and optimization opportunities.
Øyvind Kolås [Wed, 25 Apr 2018 18:22:38 +0000 (20:22 +0200)]
babl-internal: print debug output to stderr
Øyvind Kolås [Tue, 24 Apr 2018 18:15:03 +0000 (20:15 +0200)]
extensions/two-table: remove unused variable
Thomas Manni [Sun, 4 Mar 2018 09:17:07 +0000 (10:17 +0100)]
type-u8: fix u8 <> double conversions for chroma type
Øyvind Kolås [Tue, 10 Apr 2018 21:17:04 +0000 (23:17 +0200)]
postrelease version bump
Øyvind Kolås [Tue, 10 Apr 2018 21:15:57 +0000 (23:15 +0200)]
release 0.1.46
Øyvind Kolås [Tue, 10 Apr 2018 21:08:58 +0000 (23:08 +0200)]
NEWS: update
Øyvind Kolås [Sun, 8 Apr 2018 11:05:10 +0000 (13:05 +0200)]
tools: add html variant of path matrix
Øyvind Kolås [Sat, 7 Apr 2018 22:48:44 +0000 (00:48 +0200)]
docs: remove short-cut coverage, which is too expensive to generate
Øyvind Kolås [Sat, 7 Apr 2018 16:22:07 +0000 (18:22 +0200)]
extensions: remove many inline statements
When the functions are not reused by other fast path definitions, they are only
ever used as function pointers and inline is not neccesary.
Øyvind Kolås [Sat, 7 Apr 2018 15:52:02 +0000 (17:52 +0200)]
extensions/double: adds some more paths
Øyvind Kolås [Sat, 7 Apr 2018 12:19:46 +0000 (14:19 +0200)]
extensions: rename some extensions
Øyvind Kolås [Sat, 7 Apr 2018 15:04:56 +0000 (17:04 +0200)]
extensions: add more u32 short cut utility conversions
Øyvind Kolås [Sat, 7 Apr 2018 15:01:08 +0000 (17:01 +0200)]
extensions: u32<->float conversions in simple extension
They were using 'float' rather than 'double' data types for intermediate values
the lack of precision made the conversions be discarded by babl.
Øyvind Kolås [Fri, 6 Apr 2018 11:14:34 +0000 (13:14 +0200)]
extensions: add missing 32bit.c
Øyvind Kolås [Fri, 6 Apr 2018 10:40:46 +0000 (12:40 +0200)]
extensions: add some u32 fast paths
Øyvind Kolås [Thu, 5 Apr 2018 22:53:16 +0000 (00:53 +0200)]
float-half: half fast paths for premultiplied alpha
Øyvind Kolås [Thu, 5 Apr 2018 21:24:31 +0000 (23:24 +0200)]
extensions: add a double extension
This will permit slightly faster than the generic fast paths for some possibly
desired intermediate conversions. This also adds alpha stripping - which fills
in the last babl fast path currently reported missing on every launch of GIMP.
Øyvind Kolås [Wed, 4 Apr 2018 22:39:23 +0000 (00:39 +0200)]
extensions: simplify gggl/conv_rgbF_rgbaF slightly
Øyvind Kolås [Wed, 4 Apr 2018 22:15:08 +0000 (00:15 +0200)]
extensions/cairo: optimize R'G'B'A u8 to cairo-ARGB32
A combination of SIMD paths via float was beating the naive implementation in
the cairo extension, now the cairo extension comes out on top again.
Øyvind Kolås [Wed, 4 Apr 2018 21:49:55 +0000 (23:49 +0200)]
extension: add some Y' u8 fast paths
GIMP makes use of "Y' u8" to "R'G'B' u8" and we had no paths covering it,
making it go through floating point. This commit adds code paths for expanding
single grayscale u8 to R'G'B and R'G'B'A as well as R'aG'aB'aA u8.
Øyvind Kolås [Wed, 4 Apr 2018 14:41:51 +0000 (16:41 +0200)]
extensions/gegl-fixups: swap increments of src and dst in rgba8_rgb8
They were reversed, causing memory corruptions fixing bugs 794973 and 794972.
Øyvind Kolås [Wed, 4 Apr 2018 12:09:54 +0000 (14:09 +0200)]
extensions: add rgba8_rgb8 conversion that copies 24/32bit chunks
Slightly speeding up RGB u8 (without alpha) painting in GIMP, the rgba to rgb
and reverse conversions are used together with the very fast SIMD conversions
that operate on chunks of 4 components.
Øyvind Kolås [Sun, 18 Feb 2018 11:29:35 +0000 (12:29 +0100)]
post release version bump
Øyvind Kolås [Sun, 18 Feb 2018 11:27:46 +0000 (12:27 +0100)]
release 0.1.44
Øyvind Kolås [Wed, 7 Feb 2018 18:53:48 +0000 (19:53 +0100)]
babl: fix minor leak reported in bug #790924
Félix Piédallu [Mon, 29 Jan 2018 12:48:26 +0000 (13:48 +0100)]
Added mingw template pkgbuild.
Félix Piédallu [Thu, 11 Jan 2018 20:32:57 +0000 (21:32 +0100)]
Fix windows dirs_sep. Cleanup.
Félix Piédallu [Thu, 11 Jan 2018 20:26:34 +0000 (21:26 +0100)]
Remove check for linux header on win32
Félix Piédallu [Thu, 11 Jan 2018 20:25:50 +0000 (21:25 +0100)]
Remove os_win32
Félix Piédallu [Tue, 9 Jan 2018 20:48:01 +0000 (21:48 +0100)]
Temporarily disable checking for headers